import React, { Component } from "react";
// 一切皆组件
// 如果要使用路由，需要在最外面套上BrowserRouter
// Link用于做url切换的，相当于router-link标签，需要有to属性
// Route用来渲染组件，需要path属性，component属性

// vue的路由排他性路由，react的路由包容性路由
// exact表示精准匹配，只有一摸一样才能被匹配

// Switch表示分支匹配，将包容性路由转成排他性路由
import { Link, Route, Switch } from "react-router-dom";

class Home extends Component {
  render() {
    return <div>这是home组件</div>;
  }
}

class About extends Component {
  render() {
    return <div>这是About组件</div>;
  }
}

const Mine = () => {
  return <div>这是我的组件</div>;
};

class App extends Component {
  state = {};
  render() {
    return (
      <>
        <h2>react-router-basic</h2>
        <ul>
          <li>
            <Link to="/">首页</Link>
          </li>
          <li>
            <Link to="/about">关于</Link>
          </li>
          <li>
            <Link to="/mine">我的</Link>
          </li>
        </ul>

        <hr />

        <Switch>
          <Route path="/" component={Home} exact></Route>
          <Route path="/about" component={About}></Route>
          <Route path="/mine" component={Mine}></Route>
        </Switch>
      </>
    );
  }
}

export default App;
